<template>
  <div class="shopcar-container">
   <!--商品列表项区域-->
  <div class="goodslist">
    <div class="mui-card" v-for="(item, index) in goodslist" :key="index">
				<div class="mui-card-content">
					<div class="mui-card-content-inner">
          <!--v-model不能起到双向数据绑定的作用，因为store的数据只能从store取，不能反向v-model回去,而且getter的数据只能用来取-->
						<mt-switch 
            v-model="$store.getters.getGoodsSelected[item.id]"
             @change="selectedChanged(item.id,$store.getters.getGoodsSelected[item.id])"></mt-switch>
            <img src="https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2623804880,3084987642&fm=11&gp=0.jpg">
           <div class="info">
           <h1>{{item.title}}</h1>
           <p>
             <span class="price">￥{{item.sell_price}}</span>
             <numbox :initcount="$store.getters.getGoodsCount[item.id]" :goodsid="item.id"></numbox>
               <!-- 问题：如何从购物车中获取商品的数量呢 -->
              <!-- 1. 我们可以先创建一个 空对象，然后循环购物车中所有商品的数据， 把 当前循环这条商品的 Id， 作为 对象 的 属性名，
              count值作为 对象的 属性值，这样，当把所有的商品循环一遍，就会得到一个对象： { 88: 2, 89: 1, 90: 4 } -->
              <!--item.id删除localstorage的数据，index删除goodslist里面的数据-->
             <a href="#" @click.prevent="remove(item.id,index)">删除</a>
           </p>
           </div>
					</div>
				</div>
			</div>
    </div>

    <!--结算区域-->
    <div class="mui-card">
				<div class="mui-card-content">
					<div class="mui-card-content-inner jiesuan">
						<div class="left">
              <p>总计（不含运费）</p>
              <p>已勾选商品<span class="red">{{$store.getters.getGoodsCountAndAmount.count}}</span>件，总价￥<span class="red">{{$store.getters.getGoodsCountAndAmount.amount}}</span></p>
            </div>
            <mt-button type="danger">去结算</mt-button>
					</div>
				</div>
			</div>
  </div>
</template>

<script>
import numbox from '../subcomponents/shopcar_numbox.vue'
export default{
  data(){
    return{
      goodslist:[],  // 购物车中所有商品的数据
    }
  },
  created() {
    this.getGoodsList();
  },
  methods:{
    getGoodsList(){
      // 1. 获取到 store 中所有的商品的Id，然后拼接出一个 用逗号分隔的 字符串
      var idArr=[]
      this.$store.state.car.forEach(item=>idArr.push(item.id));
       // 如果 购物车中没有商品，则直接返回，不需要请求数据接口，否则会报错
      if(idArr.length<=0){
        return;
      }
      // 获取购物车商品列表
      this.$http.get('api/goods/getshopcarlist/'+idArr.join(",")).then(result=>{
        if(result.body.status===0){
          this.goodslist=result.body.message;
        }
      })
    },
    remove(id,index){
      /// 点击删除，把商品从 store 中根据 传递的 Id 删除，同时，把 当前组件中的 goodslist 中，对应要删除的那个商品，使用 index 来删除
      this.goodslist.splice(index,1);
      this.$store.commit('RemoveFromCar',id);
    },
    selectedChanged(id,val){
      //每当点击开关，把最新的开关状态同步到store中
      this.$store.commit("updateGoodsSelected",{id,selected:val})
    }
  },
  components:{
    numbox
  }
}
</script>

<style lang="scss" scoped>
.shopcar-container{
  background-color:#eee;
  overflow:hidden;
  .mui-card-content-inner{
    display:flex;
    // 纵向居中
    align-items:center;
  }
  .goodslist{
    img{
      width:60px;
      height:60px;
    }
    h1{
      font-size:13px;
    }
    .info{
      .price{
        color:red;
        font-weight:bold;
      }
    }
  }
   .jiesuan{
      display:flex;
      justify-content:space-between;
      .red{
        color:red;
        font-weight:bold;
        tont-size:16px;
      }
    }
}

</style>
